Stream是Java 8中的一个大的改进。Stream的功能是,支持集合的各种操作,比如filter, sum, max, min, average, map, reduce等等。所以我个人认为Stream的出现是基于以下原因:
- 增强集合操作
- 拥抱函数式编程
- 充分利用Lambda
- 执行效率的提高 - 透明支持多线程集合操作
笔者尝试测试一下Stream并发处理的威力,发现面对特别简单的任务,Stream并发处理相较于传统的for each循环,执行效率没有优势。看起来Stream不是免费的午餐,创建Stream还是要一些开销的。所以这促使笔者思考该在什么场景下才使用Stream。
测试例子
笔者测试两个例子,一个任务非常简单,另外一个稍微复杂一点。从结果看起来,并行Stream总是比串行快,任务简单的情况,For Loop更快,任务复杂一点,并行Stream后来居上,并行带来的改进足以cover创建Stream的开销。
测试的小工具类
public class TimeRecorder {
private long startTime;
private long endTime;
public void start() {
startTime = System.currentTimeMillis();
}
public long end() {
endTime = System.currentTimeMillis();
return endTime - startTime;
}
public long getDuration() {
return endTime